草庐IT

C++11 auto 和 size_type

全部标签

安装配置Oracle 11g 、PLSQL及使用Navicat远程连接Oracle

目录一、下载二、安装1.执行安装程序 2.配置安全更新3.安装选项4.系统类5.网络安装选项 6.选择安装类型 7.选择产品语言8.选择数据库版本9.指定安装位置10.选择配置类型​编辑11.指定数据库标识符12.指定配置选项13.电子邮箱14.指定数据库存储15.指定恢复选项16.指定方案口令17.概要18.安装页面19.安装完成三、验证安装 四、安装客户端PLSQL1.下载安装2.使用PLSQL五、使用Navicat远程连接 前言:Oracle11g是Oracle公司推出的一款关系型数据库管理系统。它于2007年发布,是Oracle数据库产品线的一部分。它提供了许多先进的功能,包括数据安全

c++ - C++11 中类型的逐字节拷贝?

C++11标准保证逐字节复制对POD类型始终有效。但是某些微不足道的类型呢?这是一个例子:structtrivial{intx;inty;trivial(inti):x(2*i){std::cout如果我要逐字节地复制这个结构,它是否能保证正确复制,即使它在技术上不是POD?什么时候画出关于什么时候不可以字节复制对象的界线? 最佳答案 是的,保证复制正确。引用FDIS,§3.9/2:Foranyobject(otherthanabase-classsubobject)oftriviallycopyabletypeT,whethero

c++ - 为什么模板 typedef 是 C++(不是 C++11)中的一个问题

在thisquestionOP要求提供模板typedef的解决方案,这在C++中是不可能的。OP自己也提出了一个解决方案,但不喜欢它:templateclassMatrix{//....};//Problem-willnotcompiletypedefMatrixVector;//SolutiontemplateclassVector:publicMatrix{};我的问题是,Helper::typesolution有什么优势?给我们OP的解决方案(假设这些类永远不会被基指针或new这样使用)?一个空类在发布时应该没有开销(或者是吗?)。我能看到的唯一缺点是,在调试构建中,您必须在调试

c++ - 在 c++/c++11 中测试 "POD-ness"?

我有一些代码采用打包的POD结构/类并将其复制到内存块中。structA{inta;intb;}a;memcpy(mymemoryblock,(void*)&a,sizeof(A));//laterIgetareplyand...memcpy((void*)&a,mymemoryblock,sizeof(A));这仅对POD类型的数据有效,我想知道是否有一种方法可以测试POD-ness。如果有人不小心给这个类添加了一个成员函数,memcpy操作就会失效,但仍然可以编译。这导致很难检测到错误。是否有is_POD_type(A)函数或其他技巧可用于在运行时或编译时检测PODness?

java - 鸭子类型(duck typing)和泛型编程

我在SO里找了一会儿,没有找到一个明确的、笼统的答案,只有一些矛盾的、特殊的意见。[1]所以我想知道鸭子类型(ducktyping)和泛型编程之间有什么关系?(DTGP)。通过泛型编程,我特别提到了C++模板或Java泛型,但如果可能的话,与概念相关的一般性答案将受到欢迎。我知道泛型编程将在编译时处理,而duck类型将在运行时处理,但我不知道如何定位它们。最后,我不想展开辩论,所以我更喜欢诸如理由、理由之类的答案。[1]What'stherelationshipbetweenC++templateandducktyping? 最佳答案

c++ - auto_ptr、immediate get() 和 release()——有用吗?

我正在处理别人的代码,其中包含很多这样的语句std::auto_ptrsmartptr(newObjectA(this));objects_list.push_back(smartptr.get());smartptr.release();这个有用吗?在这里使用智能指针而不是仅仅写有什么实际原因吗?objects_list.push_back(newObjectA(this)); 最佳答案 objects_list.push_back(newObjectA(this));这可能会泄漏内存。让我们看看当我们分解它时会发生什么:newO

C++11 decltype : How to declare the type that a pointer points to?

我有以下代码:#includeintmain(){int*a=newint(2);std::unique_ptrp(a);}导致这些错误信息:Infileincludedfroma.cpp:1:Infileincludedfrom/usr/bin/../lib64/gcc/x86_64-unknown-linux-gnu/4.9.2/../../../../include/c++/4.9.2/memory:81:/usr/bin/../lib64/gcc/x86_64-unknown-linux-gnu/4.9.2/../../../../include/c++/4.9.2/bits/

c++ - 根据 value_type 调用适当的构造函数 : integer or float

我有一个函数,它使用均匀分布将最小值和最大值之间的随机值填充到容器中。#include#include#include#includetemplatevoiduniform_random(TContainer&container,consttypenameTContainer::value_typemin,consttypenameTContainer::value_typemax){std::random_devicerd;std::mt19937gen(rd());//Belowlinedoesnotworkwithintegerscontainerstd::uniform_rea

c++ - 在哪里可以找到 C++ STL 中 vector 的 size_type 定义?

将vector的size()函数的结果转换为unsignedint似乎是安全的。不过,我怎么能确定呢?我的文档不清楚size_type是如何定义的。 最佳答案 不要假定容器大小的类型(或在其中键入的任何其他内容)。今天?目前最好的解决方案是使用:std::vector::size_type其中T是您的类型。例如:std::vector::size_typei;std::vector::size_typej;std::vector>::size_typek;(使用typedef可以帮助使其更好地阅读)对于迭代器和“内部”STL容器中的

C++11 空标志类

在一些unique_lockconstructors在C++11中,可以传递一些classes像一面旗帜,即autolock=std::unique_locklock(m,std::defer_lock);其中std::defer_lock定义为structdefer_lock{}为什么这样做,而不是使用枚举?我试图将它应用到一个小的代码示例中,但我无法编译它:classA{};voidfoo(Aa){}intmain(){foo(A);//error:'A'doesnotrefertoavalue}当我像foo(A());这样放置括号时,它起作用了,但我看不出与STL的区别。为什么这